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Field of the Invention 

The present invention relates to data communications networks and more particularly to a data commu- 
nications network having the capability of processing both high priority and low priority packets using a pre- 
5 empt-resume protocol. 

Background of the Invention 

Communications systems traditionally have used packet switching techniques for carrying bursty data traf- 

10 f ic and have used circuit switching techniques for carrying multiplexed real-time traffic such as voice and video. 

Circuit switching techniques are typified by a time-division multiplexed voice telephone network in which the ^ 
traffic is sent as a continuous stream of bits. Packet switching techniques, on the other hand, have been de- 
veloped to handle bursty data over digital networks in which destination and drop-off addresses are combined 
with the message data. Each packet is delimited by flags and contains address/routing headers, priority de- 

15 f iners and error checkers. Traditional packet networks are characterized by significant per packet processing 
in the intermediate nodes of a network. This processing has limited the throughput of packet nodes and in- 
troduced high delays for packets. To achieve higher throughput and to reduce this delay, fast packet switching 
networks have been defined which minimize the amount of processing required in intermediate nodes. 

This simplified intermediate node processing now makes it feasible for packet networks to carry, in the 

20 form of packets, traffic traditionally carried only over circuit switched networks. In addition, this traffic in packe- 
tized form can share the same packet network including communication links with the bursty data traffic. How- 
ever since the traditional circuit switched traffic had stringent bounds on total allowable delay across the net- 
work as well as variability of delay, nodes in the packet network must ensure that this traffic receives priority 
handling. To accomplish this, packets carrying bursty data tra ffjccan be assigned a non real-time priority while 

25 packets carrying the traditional circuit model traff ic can be assigned a higher, real time priority. A node in a 
fast packet network contains buffers for holding packets waiting for transmission on its communication links. 
Packets waiting for transmission can be held in buffers managed differently , depending on the priority, as- 
signed to the packets. 

A communication node in a network can adopt a number of different service policies in order to transmit 

30 packets from the different priority buffers: priority with no preemption, preemption with retransmission, and 
preemption with resume. When do preemption is used, the packet priority is only examined to determine from 
which buffer to select the next packet for transmission. If a high-priority packet is placed in the buffer while a 
low- priority packet is being transmitted, the high-priority packet must wait until the current transmission is com- 
pleted. A preemption with retransmission service policy means that the node will abort the transmission of a 

35 low-priority palcket upon the arrival of a high-priority packet and immediately transmit the high-priority packet. 
Once all high-priority packets-have been transmitted, transmission of the preempted low-priority packet will 
be restarted from the beginning of the packet. A preemption with resume service policy is similar except the 
preempted low-priority packet is restarted from the point of interruption rather than the beginning. 

The selection of the appropriate service policy is dependent on the characteristics of the communica tion 

40 link, the delay require ments of the high- priority packets, and the-size.o f the low-priorit ypackets. If the trans- 
nitssion rate of the communication linkTs high enough compared to the size of the longest low-priority packets, 
then the delay incurred by a high-priority packet waiting for a low-priority one to complete may be acceptable. 
In this case, the priority with no preemption service policy is preferable since it is easier to implement and may 
have slightly lower link overhead. If the usage efficiency of the communication link is not important but the 

45 delay associated with waiting for completion of the low-priority packets is too high, than the preemption with 
retransmission service policy may be acceptable. However, if the usage efficiency of the communication link 
is important and the priority with no preemption service policy does not meet the delay requirements, then ^ 
the preempt with resume service policy may be required. 

Various schemes exist for transmitting packetized information over communication links. The typical 

50 scheme used over low speed serial links up to T3 speeds is based ont he HDLC MAC-layer protocol. Each 
packet is delimited by starting and ending flags {X'7E'). The ending flag of one packet may also be the starting 
flag for the next packet. The packet itself consists of an integral number of bytes of data. Since the contents 
of the packet may include bit patterns that are the same as the flag pattern, a technique known as bit stuffing 
is used to differentiate the data from the flags. The transmitter inserts a '0* bit after any sequence of five con- 

55 tiguous *V bits int he packet data. Likewise, the receiver removes any *0* bit immediately following a sequence 
of five '1' bits in the received bit stream. When no packets are waiting to be transmitted, flags are repeatedly 
transmitted. 

Both the priority with no preemption and the preemption with retransmission service policies can be inv 
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plemented using the existing HDLC MAC-layer protocol. 
Summary of the invention 

5 The present invention relates to method and apparatus for effecting a nnodif ied HDLC MAC-layer protocol 

providing preemptive priority with resume over a serial communication linl<. 

It is, therefore, an object of this invention to provide method and apparatus for embedding high-priority 
traffic in low-priority for serial transmission though low speed communication linl^s, without delay incurred by 
having first to complete transmission of a low-priority traffic. It is another object of this invention to preempt 

JO low-priority packet traffic with a high-priority pacl<et and later resume transmission of the preempted tow-pri- 
ority pacl<et automatically, with minimal overhead on the communication link. It is another object of this inven- 
tion to detect bit transmission errors affecting packet boundaries and to recover from said errors with minimal 
loss of packets. It is another object of this invention to provide a method and apparatus for determining whether 
preemption of low-priority packets is required on a given communication link as a function of link speed, ac- 

15 ceptable delay and maximum packet size, and therefore whether preemption should be enabled. It is another 
object of this invention to allow a mode of operation that \s compatible with HDLC MAC-layer, either priorit to 
enabling preemption or when it is determined that preemption is not required. 

According to this invention, packets of^m^onriati^^ having starting and ending 

flagsTcontroTheiders to de^nate the^ackefs^p^ and any required routing information. The flags, in 

20 additiorHodefini^^ a packet, also define byte alignment of the packet data. The flags also 

indicate when a low-priority packet has been preempted by a high-priority packet and when the transmission 
of a low-priority packet is being resumed. The control bits designate whether or not a particular packet is high- 
priority or tow-priority and hence whether or not the packet is preemptable. 

Also when a communication link is activated, the two communications systems at each end of the link ex- 

25 change control information about their respective packet capabilities. The control information describes the 
maximum supported low-priority packet size supported in the transmit and receive direction and the ability of 
the communications system to support high-priority packets. Using the information exchanged along with the 
communication link's data rate and the maximum acceptable delay for high-priority packets, each communi- 
cations system independently determines whether the preempt/resume protocol should be enabled or whether 

30 a simple priority with no preemption the protocol should be used. 



Brief Description of the Drawings 

Figure 1 shows a basic packet frame used in the practice of this invention, where packet containing header 
35 and data is delimited by flags; 

Figure 2 shows the valid combination of formatted packet frames in which a low-priority packet is preempt- 
ed by a high-priority packet with subsequent automatic resumption; 

Figure 3 shows a combination of packet frames containing a bit error which causes a transmission abort; 
Figure 4 shows a block diagram of the transmit portion of a communication link interface of a communi- 
40 cations systems to which this invention is applicable; 

Figure 5 shows a block diagram of the receive portion of a communication link interface of a communica- 
tions system to which this invention is applicable; 

Figure 6 is a table used in explaining how maximum permissible packet size and the need for preempt/re- 
sume protocols is determined in each direction of a communication link; and 
45 Figure 7 is a finite state machine table showing preempt/resume states. 



Detailed Description of the Invention 

This invention defines a preempt/resume protocol extension to the existing HDLC MAC-layer packet fram- 
50 ing protocol used on serial communication links, to allow the preemption of low-priority packets so that high- 
priority packets may be transmitted with minimal delay. A link activation protocol is also defined to determine 
whether the preempt/resume protocol extension should be enabled. During the link activation . normal HDLC 
MAC-layer framing protocol is used to transmit packets across the communication link. Also if the link activation 
determines that preempt/resume should not be used, all packets are sent using the HDLC MAC-layer framing 
55 protocol with simple priority without preemption. 
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Enabling Preempt/Resume Protocol Extension 

Determination of when to use the preempt/resunne protocol extension is based on the support of high pri- 
ority traffic, low-priority packet sizes supported, comnnunication link speed, and maximum acceptable delay 
5 of high-priority packets. The two communications systems on each end of the communication link can deter- 
mine the need for the preempt/resume protocol independently for their direction of the link. During link- 
activation, each communications system sends a control message to its neighbor at the other end over the 
communication link using the normal HDLC MAC-layer framing. The control message contains the following 
fields : 

10 . A High-priority Traffic Supported filed indicates whether the sending system supports high-priority traf- 

fic on its link. 

. A Maximum Received Low-Priority Packet Size Supported field defines the maximum packet size that 
the sender can receive. 

. A Maximum Transmitted Low Priority Packet Size Supported field defines the maximunfi packet size that 
15 the sender can transmit . 

If high-priority traffic is not supported, the receiver must verify that each packet received is a low-priority 
packet. If a packet identified as high-priority packet is received, it is discarded by the receiver. 

The following example, described with reference to Figure 6, shows how communications systems A and 
B each determine the maximum low-priority packet size supported in each direction and whether preempt/re- 
20 sume protocol extension should be enabled. 

Transmission of a high-priority packet may not be delayed by a low-priority packet for more than T, where 
in the following example T = 0.5 msecs. A sender that supports high-priority traffic must either transmit : 

. without preempt/resume protocol, which constrains the low-priority packet size to satisfy the equation 

packet size ^ j 

25 link speed 

. or with preempt/resume. 

For link direction A to B, the maximum low-priority packet size is 8KB. Assuming a link speed of 
18.432Mbps, the above inequality is not satisfied since 

Q Kbytes ^ 3.56 msecs > 0.5 msecs 

30 1 8.432 kbits per msec 

Therefore, to satisfy the delay requirements, the preempt/resume protocol is required. This means that 
communications system A vyill transmit preempted packets and that communications system B must support 
receipt of preempted packets. 

For link direction B to A, the maximum low-priority packet size is 1KB. The above inequality is satisfied 

35 as 

Kbytes _ Q 44 msecs < 0.5 msecs 

18.432 kbits per msec 

and the preempt/resume protocol is not be used. This means that communications system B will not transmit 
preempted packets and that communications system A will interpret preempt flags as error conditions. 
40 If a particular communications system has not implemented the preempt/resume protocol extension but 

supports high-priority packets, it will select a maximum low-priority packet size to greater than the value of 
link speed x T. Using this value, the communications system on the other end of the communication link will 
correctly determine that the preempt/resume protocol is not to be used. 



Preempt/resume Protocol Extension 

In the following description, bit sequences may be described using either conventional binary represen- 
tation or, for the sake of convenience, hexadecimal representation. 

The protocol for allowing high-priority packets to temporarily preempt low- priority packets uses three types 
of flags to delimit packets : a normal flag which can be a starting, endingor idle flag, a start-preempt flag and 
an end-preempt flag. The normal flag is defined as the 8-bit sequence B'01111110'(XTe'). The star-preempt 
flag is defined as the 9-bit sequence B'011111110* and the end-preempt flag is defined as the ten-bit sequence 
B'0111111110\ All flags are on byte boundaries with respect to the packet data thatthey delineate. To differ- 
entiate flag bit sequences from bit sequences within the packets, zero bit stuffing is used in the packet data. 
An extra *0' bit is inserted in the transmitted bit stream after each occurrence of five consecutive 'V bits in a 
packet. A sequence of more than eight *V bits indicates an error condition aborting the current packet being 
transmitted and received. Also a sequence of more than six *V bits indicates an abort condition if the pre- 
empt/resume protocol is not enabled. 
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The following is a set of rules adopted for a practical preempt/resume protocol. 

. The bit sequence B'01 111110' (X7E') always defines byte alignment and may occur any number of times 

before and after complete packets. 
. Sic 'V bits preceded by a *0' bit that is not byte aligned with received packet data is an invalid code. 
5 . Nine '1' bits preceded by a '0' bit that is byte aligned is also an invalid code. 

. Receipt of an invalid code aborts the current packet and all subsequent packets are aborted until 

X'7E' occurs. 

. Verification that the preempted packet is a low priority packet is performed. 
. Verification that packets received during preemption are high-priority packets is also performed. 
10 . A low-priority packet cannot be preempted until the first byte is transmitted. 

. Receipt of the start-preempt flag (B'011111110') immediately followed by the end-preempt flag 

(B'0111111110') aborts the preempted packet and ends preempt mode. 
Under the foregoing rules, the following is a valid combination of packets and flags when preempt/resume 
is not enabled. 

iS 7E { [ 7E ] [ RTP 7E ] [ 7E ] [ NRTP 7E ] } 

Under the foregoing rules, the following is a valid combination of packets and flags when preempt/resume 
is enabled : 



7E { [ 7E ] [ RTP 7E ] [ 7E ] [ NRTP 7E ] 

^ — preempted packet ^ 

[ pNRTP { [ SP [ 7E ] RTP [ 7E RTP ] [ 7E ] EP ] pNRTP > ] } 
< preemption > 



where 

. [] denotes optional and repeatable fields 
30 . Q denotes required, repeatable fields 

. 7E represents the byte-aligned flag (8*01111110', X'7E') 
. RTP represents a high-priority packet 
. NRTP represents a low-priority packet 

. pNRTP represents portions of a preempted low-priority packet 
35 . SP represents a start-preempt flag (8*011111110*) 

. EP represents an end-preempt flag (B'0111111110') 

Figure 1 shows a conventional frame 10 delimited by normal (starting and ending) 7E flags 10a and con- 
taining both a control header 10b field and a data 10c field. 

Figure 2 illustrates in frame sequence 20 a preempt valid operation in more detail with the case of a low 

40 priority packet being preempted by two consecutive high-priority packets. The first field 20a shows the normal 
byte-aligned starting flag X'7E'. The second field 20b is an ongoing low-priority packet NRTP1 . The third field 
20c shows a start-preempt or SP flag bit by bit. This SP flag interrupts the low-priority packet and indicates 
the transmission of the remainder of the low-priority packet NRTP1 is suspended. The fourth field 20d repre- 
sents the first high-priority packet RTP1. the fifth field 20c shows the recurrence of a normal flag indicating 

45 the completion of the RTP1 packet. The transmission of the second high-priority packet RTP2 begins imme- 
diately in the sixth field 20f, without reversion to NRTP1. the seventh field 20g contains an end-preempt flag 
EP. 

Thereafter the remainder of the preempted low-priority packet NRTP1 is completed, as shown in the eighth 
field 20h. Finally, in the ninth field 20i, the norma! flag X'7E' indicates the end of NRTP1 and returns the system 
50 to the ready state. 

Figure 3 illustrates in frame sequence 30 the case of a bit error corrupting the start-preempt flag SP in 
the third field 30c. The bit error would typically be caused by a transmission error on the communication link. 
The first and second fields 30a and 30b are identical with the same fields in Figure 2. The third field 30c shows 
a double '0' at the beginning of what otherwise would be a normal flag. Since the flag does not occur on a 
55 byte-aligned boundary with respect to the low-priority packet NRTP1 in the second field 30b, then NRTP1 is 
invalid and discarded. The high-priority packet RTP1 in the fourth field 30d is saved because it is surrounded 
by valid flags in the third and fifth fields 30c and 30c. The second high-priority packet RTP2 in the sixth field 
30f is discarded, however, because it is followed by an end-preempt flag EP in the seventh field 3g. when no 
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valid start-preempt flag SP was detected due to the bit error. All packets thereafter are discarded until the nor- 
mal flag X*7E' appears, as in the ninth field 30i. 

The preempt/resume states of this invention can be summarized by a Finite State Machine (FSM) Table 
shown In Figure 7. Since this preempt/resume protocol is a "bit-oriented" protocol, the complete FSM describ- 
ing the protocol machine (the sender or the receiver) is also at the bit level. However, for the sake of clarity, 
the following describes only the FSM in terms of detected "sequences of bits", which captures those state tran- 
sitions which are associated with preemption. Furthermore, for the purpose of describing the protocol, is be- 
lieved to suffice to show the FSM for a receiver only. 

The following is a list of the FSM states, inputs and outputs (actions) along with their description. 



15 



20 



30 



35 



45 



50 



STATE DESCRIPTION 

idl Idle, expecting '7E'. 

rdy Just received 'VE' or non-byte-aligned ready to 

receive either high-priority packet or low priority 
packet 



rtp Receiving high-priority packet 

rnrtp Receiving low-priority packet 

p_rdyl Just entered preemption mode (just received start- 

preempt flag SP), ready to receive high-priority 
packet or 'IE' 

p_rdy2 In preemption mode, just received either '7E' or 

'7E**i no high-priority packet has been received yet during 

current preemption 



p_rdy3 In preemption iBode. just received either 'IE' or 

40 '7E*', ready to receive a high-priority packet, at least one 

high-priority packet has already been received during 
current preemption 



p_rrtp Receiving high-priority packet in preemption mode 



P_-idl2 Idle in preemption mode, expecting '7K', no high- 

priority packet has been received yet during the 
current preemption 

p_idl3 Idle in preemption mode, expecting *7E*, at least one 

high-priority packet has already been received during 
55 the current preemption 
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p_end 



Just exited preemption mode (just received end-preempt 
flag EP), expecting data (the continuation of the 
preempted low-priority packet) 



10 



15 



20 



25 



30 



35 



40 



45 



INPUT 



7E' share 



7E*' 



RTP 



NRTP 

SP 
EP 

IC 
or 

when 



OUTPUT 



DESCRIPTION 



Normal starting/ending/idle flag, X7E* (does not bit with prior flag) 



X7E' flag not byte-aligned with received data bytes 



Data (non-flag) byte from a high-priority packet, distinguished from NRTP by a control bit 
in the first byte of a string, indicating packet priority. Zero bit stuffing is performed on se- 
quences of these bytes. 



Data (non-flag) byte from a low-priority packet, distinguished from RTP by a control bit in 
the first byte of a string indicating packet priority. Zero bit stuffing is performed on se- 
quences of these bytes. 



Start-preempt flag B*011111110' (seven I's) 
End-preempt flag B'O111111110' (eight 1's) 

Invalid codes, include non-byte-aligned SP, non-byte-aligned EP, a run of six '1' bits right 
after a flag 

B'0111111111 (nine 1's), or B'01111111 (seven Vs) 

preempt/resume is not enabled 



DESCRIPTION 



50 
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strt_R Indicate start of received high-priority packet and 

5 forward first byte 

strt_N Indicate start of received low-priority packet and 

forward first byte 

10 

inore_R Forward another byte of high-priority packet 



15 



more_N Forward another byte of low-priority packet 

end_R Indicate end of received high-priority packet 

end_N Indicate end of received low-priority packet 

abrt_R Abord/discard current received high-priority packet 

25 abrt_RN abord/discard both preempting high-priority packet and 
the preempted low-priority packet 



20 



30 Note that states p_rdy1, p_rdy2 and p_rdy3 are similar in that the receiver is in the preempt mode and 

expecting a high-priority packet in all these states. However, it is necessary to have p_rdy1 and p_rdy2 to en- 
sure that all packets are recovered when surrounded by normal flags. Likewise, p_rdy2 and p_rdy3 are needed 
to tell whether or not it is legal to receive the end-preempt (EP) flag. 

35 Embodiment of Communication Link Interfaces 

Figure 4 shows a block diagram of the transmitter 40 portion of the communication link interface of that 
communications system. Packets arrive from the communications system's packet source 41 for transmission 
on communication link 48. The packets may have been generated locally by this system or may have been 

40 received from another communication link on this system (e.g. an intermediate node in a packet network). The 
communications system places the high-priority packets into a high priority buffer 42 and places the low-priority 
packets into a low priority buffer 43. If no packets are stored in either high priority buffer 42 or low priority buffer 
43, a flag generator 46 is connected to the communication link 48 via a bit multiplexer 47. The flag generator 
46 repeatedly generates an idle flag X*7E', when no packets are stored for transmission. 

45 When a low-priority packet arrives in the low priority buffer 43 and a packet is currently being transmitted, 

the transmitter 40 waits until all earlier packets in the low priority buffer 43 have been transmitted and the high 
priority buffer 42 is empty. When a low-priority packet is at the head of the low priority buffer 43 and no other 
packet is being transmitted on the communication link 48, bytes from the low priority buffer 43 are transferred 
one at a time through a byte multiplexer 44 to a parallel serial converter 45. The parallel serial converter 45 

50 serializes the data and monitors the outgoing data for sequences of five consecutive 'V bits. It also inserts a 
single '0' bit immediately after each set of five '1* bits. The resulting bit stream is routed through the bit to the 
communication link 48. When the transmission of the low-priority packet is complete, the bit multiplexer 47 
selects the flag generator 46 for transmission to send at least one or more normal flags until the next packet 
is ready to be transmitted. Note that each time a flag is sent, the parallel serial converter 45 resets its internal 

55 count of the number of consecutive 'V bits. 

If a low-priority packet is being transmitted from low priority buffer 43 and a high-priority packet arrives in 
the high priority buffer 42, then the transmission of the low-priority packet is preempted. The remaining bits 
int he parallel serial converter 45 along with any stuffed zero bits are transmitted guaranteeing a data byte 
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boundary for the preempted packet, and then the flag generator 46 sends special start-preempt flag described 
earlier. Bytes from the high priority buffer 42 are then transferred through the byte multiplexer 44 to the parallel 
serial converter 45 which performs serialization and zero bit stuffing. The resulting high-priority packet is then 
transferred to the communication link 48. If, during the transmission of the high-priority packet, another high- 
priority packet arrives in the high-priority buffer 42, the n the flag generator 46 sends a normal flag when the 
first high-priority packet is completed and transmitter 40 begins transmission of the next high-priority packets 
without exiting the preempt mode. When the last of the series of high-priority packets has been sent (there 
are not more packets waiting in the high priority buffer 42), the flag generator 46 sends the end-preempt flag 
described earlier. The remaining bytes from the preempted low-priority packet in the low priority buffer 43 are 
the released to the parallel serial converter 45 and the communication link 48. If a subsequent high-priority 
packet arrives at the high-priority buffer 42 prior to the completion of the preempted low-priority packet, the 
preemption and resume sequence is repeated. When the transmission of the low-priority packet is completed, 
the flag generator 46 transmits a normal ending flag. 

Figure 5 shows a block diagram of the receiver 50 portion of the communication link interface of the com- 
munications system up to a point at which received whole packets are passed to a packet target 56 within the 
communications system. The packet target 56 could be the final destination for the received packets or could 
be a packet switch used to route packets to other communication links for transmission to other nodes in a 
packet network. Any buffering associated with the packet target 56 is outside the receiver 50 and is not in- 
cluded in Figure 5. 

A flag detector 52 continuously mon itors the bit stream received fr om a cornmujiLcM QA'inb_511^^ 
start-preempt and end- preempt flags. If a sequenceof *bits"otmr than a flag is detected immediately following 
alnoTmaj'Tla^^ the beginning of a new frame. A serial parallel converter 53 receives the bit stream, 

discard any '0' bit if it immediately follows five consecutive '1' bits, and converts the remaining bits into byte- 
parallel form. If the received packet is a high-priority . packet, the parallel byte data is passed directly through 
a multiplexer 59 to a multiplexer 55 connected to the packet target 56 until a normal ending flag is detected 
by the flag detector 52. The receiver 50 indicates the end of the packet to the packet target 56. 

If the received packet can be preempted (i.e. low-priority, non-real-time packet), then the parallel byte data 
is instead passed through byte multiplexer 59 to the preemptable packet buffer 54 in order to permit the entire 
packet to be accumulated before passing it to the packet target 56. If flag detector 52 detects a start-preempt 
flag and there is no partial byte in the serial parallel converter 53, then it indicates the beginning of a high- 
priority preempting packet and therefore the beginning of preempt mode. The bit stream is passed through 
the serial parallel converter 53 as before but this time the parallel byte data is passed directly through the mul- 
tiplexers 59 and 55 to the packet target 56 within the communications system. 

When the flag detector 52 detects either an normal ending flag or an end-preempt flag, then the receiver 
50 indicates the end of the packet to the packet target 56. If a normal ending flag is detected, then the serial 
parallel converter 53 will continue to route the parallel byte data from subsequent packets directly to the mul- 
tiplexer 55. If an end-preempt flag is detected, the receiver 50 will end preempt mode. The received bit stream 
will be routed through the serial parallel converter 53 and multiplexer 59 to the preemptable packet buffer 54 
thus resuming reception of the preempted low-priority packet . If the flag detector 52 detects a normal ending 
flag indicating the end of the low-priority packet, the receiver 50 transfers the entire low-priority packet stored 
in the preemptable packet buffer 64 through the multiplexer 55 to the packet target 56. 

Figure 5 assumes that the transfer of a whole packet from the preemptable packet buffer 54 to the packet 
target 56 is accomplished before the first parallel data byte from a subsequent packet can be received. If the 
transfer takes longer than this in a particular implementation, a FIFO buffer can be placed after the serial par- 
allel converter 53 to temporarily hold t he receive data bytes until the transfer from the preemtable packet buffer 
54 is complete. Also in some implementations, high-priority packets may be passed to separate packet targets. 
In this case, the preemptable packet buffer 54 is not required. 



Claims 

1. A packet-switched communications system for mixed low-priority and high-priority traffic characterized 
in that it comprises: 

means for embedding high-priority packets within low-priority packets based on distinctive pattern codes 
attached to said packets, 

means responsive to a distinctive start-preempt pattern 
for transmitting the high-priority packet immediately. 

means for buffering a low-priority packet that may be preempted by a high-priority packet, and 
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means responsive to a distinctive end-preempt pattern for resuming transmission of a preempted low-pri- 
ority packet temporarily stored in said buffering means. 

A communications system for transmitting mixed low-priority and high-priority traffic characterized in that 
it comprises: 

means for distinguishing between low-priority and high-priority packets, 

means for generating a start-preempt pattern to interrupt transmission of a low-priority packet, 
means for buffering remainder of low-priority packet that has been preempted, 

means for generating an end-preempt pattern at the completion of transmission of all high-priority packets 
and the resumption of transmission of the interrupted low-priority packet. 

A communication system according to claim 2 in which: 

said distinguishing means is a pattern detector having stored therein the patterns identifying respectively 
a low-priority packet and a high-priority packet and further having comparative means for matching re- 
ceived patterns with said stored patterns. 

A communications system for receiving mixed low-priority and high-priority traffic characterized in that it 
comprises: 

means for distinguishing between low-priority and high-priority received packets, 
means for detecting start of preempting high-priority packets, 

means for comparing bit patterns in received signals with stored distinctive flag patterns to determine 

whether a particular pattern is a complete packet or an interrupted low-priority packet, 

means for receiving multiple high-priority packet without resuming preempted low-priority packet; 

means for buffering low-priority packet that may be preempted by a high-priority packet, 

means for resuming reception of preempted low-priority packet, 

means for completing low-priority packet temporarily stored in said buffering means. 

A method for embedding high-priority communication packets within low-priority communication packet 
in a packet-switched communications system characterized in that it comprises the steps of: 

a) prefixing each low-priority packet with a characteristic start flag; 

b) prefixing each high-priority packet with a characteristic start-preempt pattern of bits; 

c) suffixing each low-priority packet with a characteristic ending flag; 

d) suffixing each high-priority packet with a characteristic end-preempt pattern of bits; 

e) using the starting flag to initiate transmission of packets and to establish byte alignment with a packet 
frame; 

f) using the start-preempt pattern of bits to interrupt 

the transmission of low-priority packets and buffer non-transmitted low-priority bits while transmission 
of high-priority bits continues; 

g) using the end-preempt pattern of bits following the completion of transmission of a high-priority pack- 
et to indicate the resumption of the transmission of the interrupted low-priority packet; and 

h) using the ending flag to return the communications system to the idle state. 

A method for receiving packet-switched communication signals in which high-priority packets are embed- 
ded in low-priority packets characterized in that it comprises the steps of: 

a) monitoring incoming signal bit streams for the presence of preassigned patterns of starting and end- 
ing 

flags and start-preempt and end-preempt flags; 

b) responding to a starting flag to effect byte alignment and to enter a ready state for receiving and 
buffering low-priority packets; 

c) responding to a start-preempt flag to suspend reception of low-priority packet and accept and relay 
a high-priority packet immediately; 

d) responding to an end-preempt flag to resume reception of the suspended low-priority packet; 

e) responding to an ending flag to relay the completed low-priority packet, 

0 responding to the failure to detect an end-preempt flag after a high-priority packet by aborting further 
reception until a normal flag occurs. 

A method for receiving packet-switched communication signals according claim 6 further comprising: 

set of flag conditions that when received return the receiver to a non-error state. 

set of error states that allow recovering of some packets prior to returning to a non-error state, and 
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a finite state machine defining the conditions under which transitions occur between non-error and error 
states. 

A method for communications systems at each end of a communication links to determine whether 
preempt/resume is required for each link-direction at the time of link activation characterized m that it com- 
prises: 

means to exchange link capabilities between adjacent communication systems over the communications 
systems over the communication link at link activation time, 

means for each communications system to independently computer whether preempt/resume protocol ex- 
tension should be enable, and 

means for communications systems not supporting preempt/resume protocol extension to activate link 
with communications system supporting extension. 
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A protocol is defined for mixed 
data/voice/multimedia communications sys- 
tems to transmit and receive high-priority, 
real-time traffic over low-speed digital com- 
munication links by embedding such high- 
priority traffic in low-priority, non-real-time traf- 
fic. High-priority, real-time packets are thus 
transmitted without delay by preempting low- 
priority packets. Low-priority, non-real-time 
packets are held during preemption, and low 
-priority transmission is automatically resumed 
after transmission of high-priority packets has 
been completed. A protocol is defined for com- 
munications systems to exchange information, 
at the time that a communication link is acti- 
vated, defining their link capabilities for hand- 
ling high-priority, real-time packets and to 
agree on how this high-priority traffic will be 
transmitted on the communication link. 
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1. Claims 1-7 : Packet switched communications system for 

mixed low-priority and high-priority traffic 
characterised in that it comprises means for 
embedding. high-priority packets within low- 
priority packets. 

2. Claim* 8 : A method for communications systems at each 

end of a communication link to determine 
whether preempt/resume is required for each 
link direction at the time of link activation. 
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